Information processing apparatus and method, and recording medium

ABSTRACT

An information processing apparatus includes a first recurrent neural network (RNN) for performing processing which corresponds to a time-series and a second RNN for processing another correlated time-series. The difference between a context set output by the first RNN and a context set output by the second RNN is computed by a subtractor, and the obtained difference is used as a prediction error. Backpropagation is performed based on the prediction error, thus determining a coefficient for each neuron of an output layer, an intermediate layer, and an input layer.

BACKGROUND OF THE INVENTION

[0001] 1. Field of the Invention

[0002] The present invention relates to information processing apparatuses and methods and recording media, and more specifically, relates to an information processing apparatus and method and a recording medium in which different time-series patterns which are correlated with each other can be learned.

[0003] 2. Description of the Related Art

[0004] For example, various research on artificial intelligence which is applicable to robots has been conducted. In an article entitled “Reinforcement Learning With Hidden States”, Long-Ji Lin proposes combining prediction and reward learning using a recurrent neural network (RNN).

[0005] In an article entitled “Learning to predict by the methods of temporal differences”, Machine Learning, 3: 9-44, 1988, R. S. Sutton proposes combining an internal model and reward learning. Reinforcement learning of action policies has been conducted through rehearsals using an internal model.

[0006] However, none of the proposed techniques accomplishes learning of different time-series which are correlated with each other.

SUMMARY OF THE INVENTION

[0007] Accordingly, it is an object of the present invention to accomplish learning of different time-series which are correlated with each other.

[0008] According to an aspect of the present invention, a first information processing apparatus is provided including a first recurrent neural network and a second recurrent neural network. One of the first recurrent neural network and the second recurrent neural network learns based on a context output by the other recurrent neural network.

[0009] Preferably, one of the first recurrent neural network and the second recurrent neural network learns to output a context which corresponds to the context output by the other recurrent neural network in a predetermined state.

[0010] According to another aspect of the present invention, a first information processing method for an information processing apparatus including a first recurrent neural network and a second recurrent neural network is provided. The method includes a learning step of learning, by one of the first recurrent neural network and the second recurrent neural network, based on a context output by the other recurrent neural network.

[0011] According to a further aspect of the present invention, a first recording medium having recorded therein a computer-readable program for an information processing apparatus including a first recurrent neural network and a second recurrent neural network is provided. The program includes a learning step of learning, by one of the first recurrent neural network and the second recurrent neural network, based on a context output by the other recurrent neural network.

[0012] According to yet another aspect of the present invention, a second information processing apparatus is provided including a first recurrent neural network and a second recurrent neural network. One of the first recurrent neural network and the second recurrent neural network includes a processing unit for performing inverse dynamics processing based on a context output by the other recurrent neural network.

[0013] According to yet another aspect of the present invention, a second information processing method for an information processing apparatus including a first recurrent neural network and a second recurrent neural network is provided. The method includes a processing step of performing, by one of the first recurrent neural network and the second recurrent neural network, inverse dynamics processing based on a context output by the other recurrent neural network.

[0014] According to still another aspect of the present invention, a second recording medium having recorded therein a computer-readable program for an information processing apparatus including a first recurrent neural network and a second recurrent neural network is provided. The program includes a processing step of performing, by one of the first recurrent neural network and the second recurrent neural network, inverse dynamics processing based on a context output by the other recurrent neural network.

[0015] According to a first information processing apparatus, a first information processing method, and a program recorded in a first recording medium, one of a first recurrent neural network and a second recurrent neural network learns based on a context output by the other recurrent neural network.

[0016] According to a second information processing apparatus, a second information processing method, and a program recorded in a second recording medium, one of a first recurrent neural network and a second recurrent neural network performs inverse dynamics processing based on a context output by the other recurrent neural network.

BRIEF DESCRIPTION OF THE DRAWINGS

[0017]FIG. 1 shows the external structure of a robot to which the present invention is applied;

[0018]FIG. 2 is a block diagram of the internal structure of the robot shown in FIG. 1;

[0019]FIGS. 3A illustrates the structure of a recurrent neural network 31-1 forming a neural net recognition unit shown in FIG. 2;

[0020]FIG. 3B illustrates the structure of another recurrent neural network 31-2 forming the neural net recognition unit shown in FIG. 2;

[0021]FIG. 4 is a flowchart showing a learning process performed by the recurrent neural networks 31-1 and 31-2 shown in FIGS. 3A and 3B;

[0022]FIG. 5 is a state transition diagram of the recurrent neural network 31-1 shown in FIG. 3A;

[0023]FIG. 6 is a state transition diagram of the recurrent neural network 31-2 shown in FIG. 3B;

[0024]FIG. 7 is a phase-plot graph corresponding to the state transition diagram shown in FIG. 5;

[0025]FIG. 8 is a phase-plot graph corresponding to the state transition diagram shown in FIG. 6;

[0026]FIG. 9 illustrates time-series variations in sensors and actions involved in the state transitions shown in FIGS. 5 and 6;

[0027]FIG. 10 is a flowchart showing details of the learning process using binding in step S2 in FIG. 4;

[0028]FIG. 11 illustrates a binding learning process performed by the recurrent neural network 31-1 shown in FIG. 3A;

[0029]FIG. 12 illustrates a binding learning process performed by the recurrent neural network 31-2 shown in FIG. 3B;

[0030]FIG. 13 illustrates an example of processing performed by the recurrent neural networks 31-1 and 31-2;

[0031]FIG. 14 illustrates actions taken by the robot;

[0032]FIG. 15 illustrates the operation of the recurrent neural networks 31-1 and 31-2 shown in FIGS. 3A and 3B in response to a context set; and

[0033]FIG. 16 illustrates the operation of the recurrent neural networks 31-1 and 31-2 shown in FIGS. 3A and 3B in response to a context set.

DESCRIPTION OF THE PREFERRED EMBODIMENTS

[0034]FIG. 1 shows the external structure of a robot to which an information processing apparatus of the present invention is applied. In this example, a TV camera 12 which functions as a sensor is mounted on top of a robot 11, and the TV camera 12 captures environmental images. Wheels 13 are located on the underside of the robot 11, and hence the robot 11 can move to an arbitrary position. A display 14 is attached on a lateral side of the robot 11, and the display 14 displays predetermined characters and images if necessary. A sensor 15 detects environmental information of the robot 11.

[0035]FIG. 2 shows the internal structure of the robot 11. The TV camera 12 captures an environmental image as a color image and outputs the captured color image data to a control circuit 24 and a quantization circuit 25. The quantization circuit 25 quantizes the input color image data and outputs the quantized data to a neural net recognition unit 23. The sensor 15 outputs various detected information to the control circuit 24. The neural net recognition unit 23 recognizes the color image data input by the quantization circuit 25 and outputs the result to the control circuit 24. For example, the control circuit 24 is formed of a microcomputer or the like. The control circuit 24 informs the neural net recognition unit 23 of the direction in which the robot 11 is moving. Also, the control circuit 24 outputs a prediction result supplied by the neural net recognition unit 23 to the display 14 which is formed of a CRT or an LCD, and the display 14 displays the prediction result.

[0036] The control circuit 24 drives a motor 21 in order to direct the TV camera 12 in a predetermined direction. The control circuit 24 also drives a motor 22 in order to rotate the wheels 13, thereby moving the robot 11 to a predetermined position.

[0037]FIGS. 3A and 3B illustrate an example of the structure of the neural net recognition unit 23. The neural net recognition unit 23 is formed of a recurrent neural network (RNN) 31-1 shown in FIG. 3A and a recurrent neural network (RNN) 31-2 shown in FIG. 3B. The RNN 31-1 includes an input layer 41-1 which includes a predetermined number of neurons. The control circuit 24 inputs signals which correspond to states of various sensors 15 (including the TV camera 12) (hereinafter referred to as sensor) S₁(t) and action A₁(t) to individual neurons of the input layer 41-1. Data input to the input layer 41-1 passes through an intermediate layer 42-1 which includes a predetermined number of neurons and an output layer 43-1 which includes a predetermined number of neurons. The output layer 43-1 outputs the data as sensor S₁(t+l) and action A₁(t+l).

[0038] By performing predetermined learning, each neuron stores a predetermined weight coefficient. The neuron multiples an input by the weight coefficient and outputs the product to another neuron. A context C₁(t+l), which is part of an output from a predetermined neuron of the output layer 43-1, is supplied as feedback to neurons of the input layer 41-1.

[0039] As in the RNN 31-1, the RNN 31-2 includes an input layer 41-2, an intermediate layer 42-2, and an output layer 43-2. The control circuit 24 inputs S₂(t) corresponding to states of various sensors 15 and action A₂(t) to individual neurons of the input layer 41-2. Data input to the input layer 41-2 passes through the intermediate layer 42-2 having a predetermined number of neurons and the output layer 43-2 having a predetermined number of neurons. The output layer 43-2 outputs the data as sensor S₂(t+1) and action A₂(t+1).

[0040] By performing predetermined learning, each neuron stores a predetermined weight coefficient. The neuron multiples an input by the weight coefficient and outputs the product to another neuron. A context C₂(t+1), which is part of an output from a predetermined neuron of the output layer 43-2, is supplied as feedback to neurons of the input layer 41-2.

[0041] The RNN 31-1 receives sensor S₁(t) and action A₁(t) at the current time (step) t, and the RNN 31-1 predicts and outputs sensor S₁(t+1) and action A₁(t+1) at the subsequent time (step) t+1. By performing behavior learning, the RNN 31-1 stores the relationship between the current time and the subsequent time by gradually changing the connection weight. Specifically, in response to the input of sensor S₁(t) and action A₁(t) at the current time, the RNN 31-1 learns to predict sensor S₁(t+1) and action A₁(t+1) which will be obtained at the subsequent time (step).

[0042] The same applies to the RNN 31-2.

[0043]FIG. 4 shows a learning process performed by the RNNs 31-1 and 31-2. In step S1, the RNNs 31-1 and 31-2 determine whether or not a user has given a binding command. If the determination is affirmative, the RNNs 31-1 and 31-2 perform the learning process by binding in step S2. In step S3, the RNNs 31-1 and 31-2 determine whether or not the user has given a terminating command. If the determination is negative, the RNNs 31-1 and 31-2 return to step S1, and the processing from step S1 onward is repeated. If the determination in step S3 is affirmative, the process is terminated.

[0044] More specifically, when the robot 11 moves along a predetermined path, the RNN 31-1 goes through a state transition shown in FIG. 5, and the RNN 31-2 goes through a state transition shown in FIG. 6. In FIGS. 5 and 6, numerals enclosed in parentheses [ ] are two values of sensor S₁(t+1) output by the output layer 43-1 or two values of sensor S₂(t+1) output by the output layer 43-2, respectively. A numeral which corresponds to an arrow indicating a transition from a predetermined state to another state represents action A₁(t) or A₂(t) which is input to the input layer 41-1 or 41-2, respectively.

[0045] As shown in FIG. 5, in the RNN 31-1, for example, the output values of sensor S₁ at state F are [0.2 0.4]. When “1” is input as action A1 at state F, the state changes from state F to state A, and the output values of sensor S₁ become [0.8 0.3].

[0046] When “0” is input as action A₁ at state A, the state changes to state E, and the output values of sensor S₁ become [0.5 0.2].

[0047] When “0” is input as action A₁ at state E, the state changes to state C, and the output values of sensor S₁ become [0.1 0.5]. When “1” is input as action A₁ at state E, the state changes from state E to state B, and the output values of sensor S₁ become [0.2 0.2].

[0048] When “1” is input as action A₁ at state B, the state changes to state F, and the sensor S₁ outputs [0.2 0.4].

[0049] Alternatively, when “0” is input as action A₁ at state B, the state changes to state C, and the sensor S₁ outputs [0.1 0.5].

[0050] When “1” is input as action A₁ at state C, the state changes to state G, and the sensor S₁ outputs [0.1 0.9]. When “0” is input as action A₁ at state G, the state changes to state C.

[0051] Alternatively, when “0” is input as action A₁ at state C, the state changes to state D, and the sensor S₁ outputs [0.9 0.9].

[0052] When “1” is input as action A₁ at state D, the state changes to state C. Alternatively, when “0” is input as action A₁ at state D, the state changes to state A.

[0053] Referring to FIG. 6, in the RNN 31-2, the outputs of sensor S₂ at state a are [0.9 0.6]. When “0” is input as action A₂ at state a, the state changes to state k, and the sensor S₂ outputs [0.5 0.2].

[0054] When “1” is input as action A₂ at state k, the state changes to state c, and the sensor S₂ outputs [0.1 0.9].

[0055] When “1” is input as action A₂ at state c, the state changes to state g, and the sensor S₂ outputs [0.1 0.7]. When “1” is input as action A₂ at state g, the state changes to state h, and the sensor S₂ outputs [0.1 0.5].

[0056] When “0” is input as action A₂ at state h, the state changes to state c.

[0057] When “0” is input as action A₂ at state k, the state changes to state b, and the sensor S₂ outputs [0.5 0.5]. When “0” is input as action A₂ at state b, the state changes to state a. Alternatively, when “1” is input as action A₂ at state b, the state changes to state i, and the sensor S₂ outputs [0.1 0.4].

[0058] When “0” is input as action A₂ at state i, the state changes to state c.

[0059] When “0” is input as action A₂ at state c, the state changes to state d, and the sensor S₂ outputs [0.2 0.1].

[0060] When “1” is input as action A₂ at state d, the state changes to state c. Alternatively, when “0” is input as action A₂ at state d, the state changes to state j, and the sensor S₂ outputs [0.6 0.6]. When “0” is input as action A₂ at state j, the state changes to state a.

[0061] In FIGS. 5 and 6, although there is discrimination between lowercase and uppercase characters, states indicated by the same letter correspond to each other. For example, state A and state a, state B and state b, state C and state c, state D and state d, and state G and state g correspond to each other, respectively. States E and F in FIG. 5 do not correspond to any states in FIG. 6, nor do states h to k in FIG. 6 correspond to any states in FIG. 5.

[0062] A state is said to be in correspondence with another state when the RNN 31-1 and the RNN 31-2 are highly correlated.

[0063]FIG. 7 is a graph showing a phase plot of context values at various states of the RNN 31-1 shown in FIG. 5. Referring to FIG. 7, the average value of a predetermined group of contexts output by the RNN 31-1 is shown on the abscissa, and the average value of another group is shown on the ordinate. Specifically, the graph in FIG. 7 can be obtained by projecting phases (states) formed of context elements on a two-dimensional plane defined by the average values of two groups of contexts. On the projected plane, states A to D in FIG. 7 are indicated by corresponding symbols.

[0064] Similarly, FIG. 8 is a phase plot of various states of the RNN 31-2 shown in FIG. 6. Referring to FIG. 8, states a to d in FIG. 6 are indicated by corresponding symbols.

[0065] By comparing FIGS. 7 and 8, it can be concluded that states A to D in FIG. 7 are represented at positions (on coordinates) which substantially correspond to states a to d in FIG. 8. Accordingly, it means that states A to D are highly correlated with states a to d, respectively.

[0066] The user gives a command to execute the learning process by binding in step S2 in FIG. 4 when states from among those in FIGS. 5 and 6 correspond to each other (when states are highly correlated with each other). Thus, when it is determined in step S1 that the RNN 31-1 is at one of states A to D and G and the RNN 31-2 is at one of states a to d and g, the learning process by binding is performed. If the RNN 31-1 is at one of the other states E and F and the RNN 31-2 is at one of the other states h to k, no command is input. In this case, the learning process by binding is not performed.

[0067]FIG. 9 illustrates time-series of sensors and actions of the RNN 31-1 and RNN 31-2, which correspond to step-by-step movement of the robot 11. Concerning the RNN 31-1, step n+1 corresponds to state F in FIG. 5, and step n+2 corresponds to state A, step n+3 corresponds to state E, and step n+4 corresponds to state C. In contrast, concerning the RNN 31-2, step n+2 corresponds to state a, step n+3 corresponds to state k, and step n+4 corresponds to state c.

[0068] In the time-series in which the state undergoes transition, the learning process by binding is performed in corresponding state steps (step n+2 and step n+4 in FIG. 9).

[0069] The learning process by binding is performed in a manner illustrated by a flowchart in FIG. 10. The learning process is performed by the RNN 31-1 and the RNN 31-2, respectively.

[0070] In step S11, a prediction error is generated. In the RNN 31-1, as shown in FIG. 11, a context set output by the RNN 31-2 is input to a subtractor 51-1. The difference between the context set of the RNN 31-2 and a context set output by the 31-1 is computed as a prediction error. In step S12, backpropagation is performed based on the prediction error obtained in step S11, thereby determining a coefficient for each neuron of the output layer 43-1, the intermediate layer 42-1, and the input layer 41-1 in order to minimize the prediction error.

[0071] Similarly, in the RNN 31-2, as shown in FIG. 12, a context set of the RNN 31-1 is input to a subtractor 51-2. The difference between the context set of the RNN 31-1 and a context set output by the RNN 31-2 is computed as a prediction error. Backpropagation is performed based on the prediction error to determine a coefficient for each neuron of the output layer 43-2, the intermediate layer 42-2, and the input layer 41-2 in order to minimize the prediction error.

[0072] For example, the RNN 31-1 performs processing with regard to actions of the robot 11, and the RNN 31-1 performs speech recognition processing. Referring to FIG. 13, the robot 11 is made to detect an apple 61, to move to the apple 61, and to touch the apple 61. In accordance with these actions, the RNN 31-2 processes speech messages such as “touch the apple”, “touch the round thing”, and “touch, round thing”. Thus, the correlation between the actions by the RNN 31-1 and the speech recognition by the RNN 31-2 is learned.

[0073] Referring to FIG. 14, the apple 61 and a banana 71 are placed in a field in which the robot 11 is set. By inputting a message such as “Is there an apple?” to the robot 11, the robot 11 is made to detect the apple 61. Also, by inputting a message such as “Pick it up” to the robot 11, the robot 11 is made to move to a position in front of the apple 61 and to pick up the apple 61.

[0074] Referring to FIG. 15, for example, predetermined speech is input to the RNN 31-2. In response to this, the RNN 31-2 performs forward dynamics processing and obtains a context set. The context set is supplied to the RNN 31-1, and the RNN 31-1 in turn performs inverse dynamics processing. As a result, a predetermined action can be output.

[0075] In contrast, as shown in FIG. 16, a predetermined action is input to the RNN 31-1. In response to this, the RNN 31-1 performs forward dynamics processing and obtains a context set. The context set is supplied to the RNN 31-2, and the RNN 31-2 in turn performs inverse dynamics processing. As a result, predetermined speech can be output.

[0076] If necessary, the forward dynamics processing and the inverse dynamics processing performed by the RNN 31-1 and the RNN 31-2 are repeated a predetermined number of times by inputting an output as feedback.

[0077] Although a case in which the present invention is applied to a robot has been described, the present invention is also applicable to other information processing apparatuses.

[0078] Concerning a recording medium which provides users with a computer program for performing the foregoing processing, a magnetic disk, a CD-ROM, or a solid-state memory can be used. It is also possible to transfer a program in such a recording medium through a network or a satellite and to store the program in the recording medium. 

What is claimed is:
 1. An information processing apparatus comprising: a first recurrent neural network; and a second recurrent neural network; wherein one of said first recurrent neural network and said second recurrent neural network learns based on a context output by the other recurrent neural network.
 2. An information processing apparatus according to claim 1, wherein one of said first recurrent neural network and said second recurrent neural network learns to output a context which corresponds to the context output by the other recurrent neural network in a predetermined state.
 3. An information processing method for an information processing apparatus including a first recurrent neural network and a second recurrent neural network, the method comprising: a learning step of learning, by one of said first recurrent neural network and said second recurrent neural network, based on a context output by the other recurrent neural network.
 4. A recording medium having recorded therein a computer-readable program for an information processing apparatus including a first recurrent neural network and a second recurrent neural network, the program comprising: a learning step of learning, by one of said first recurrent neural network and said second recurrent neural network, based on a context output by the other recurrent neural network.
 5. An information processing apparatus comprising: a first recurrent neural network; and a second recurrent neural network; wherein one of said first recurrent neural network and said second recurrent neural network comprises processing means for performing inverse dynamics processing based on a context output by the other recurrent neural network.
 6. An information processing method for an information processing apparatus including a first recurrent neural network and a second recurrent neural network, the method comprising: a processing step of performing, by one of said first recurrent neural network and said second recurrent neural network, inverse dynamics processing based on a context output by the other recurrent neural network.
 7. A recording medium having recorded therein a computer-readable program for an information processing apparatus including a first recurrent neural network and a second recurrent neural network, the program comprising: a processing step of performing, by one of said first recurrent neural network and said second recurrent neural network, inverse dynamics processing based on a context output by the other recurrent neural network. 